<!--
/**
 * 项目管理 列表页 JS 脚本
 * @author 金杰 , maillank@qq.com
 * @since 2025-07-06 14:15:23
 */
 -->
 <!DOCTYPE html>
<html>

<head>
    <meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1">
    <meta charset="utf-8"/>
    <meta name="referrer" content="no-referrer">
    <title th:text="${lang.translate('项目管理')}">项目管理</title>
    <link th:if(theme.ico!="null") rel="shortcut icon" th:href="${theme.ico}" type="image/vnd.microsoft.icon">
    <link th:if(theme.ico!="null") rel="icon" th:href="${theme.ico}" type="image/vnd.microsoft.icon">
    <meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1">
    <link rel="stylesheet" href="/assets/libs/layui/css/layui.css" th:href="'/assets/libs/layui/css/layui.css?'+${cacheKey}"/>
    <link rel="stylesheet" href="/assets/css/admin.css" th:href="'/assets/css/admin.css?'+${cacheKey}"/>
    <link rel="stylesheet" href="/assets/libs/toast/css/toast.css" type="text/css" th:href="'/assets/libs/toast/css/toast.css?'+${cacheKey}">
    <link rel="stylesheet" href="/assets/css/foxnic-web.css" th:href="'/assets/css/foxnic-web.css?'+${cacheKey}">
    <link href="/assets/libs/font-awesome-4.7.0/css/font-awesome.min.css" rel="stylesheet"/>
    <link href="/assets/libs/material-design-webfont/css/material-design-icons-min.css" rel="stylesheet">
    <script th:inline="javascript">var foxnic_cachekey=[[${cacheKey}]];</script>
    <style>
    </style>
    <link th:each="css:${theme.css}" rel="stylesheet" th:href="${css}+'?'+${cacheKey}">
</head>

<body style="overflow-y: hidden">

<div class="layui-card">

    <div class="layui-card-body" style="">

        <div class="search-bar" style="">

            <div class="search-input-rows" style="opacity: 0">
                <!-- 搜索输入区域 -->
                <div class="layui-form toolbar search-inputs">
                    <!-- 关联合同 , contractId ,typeName=select_box, isHideInSearch=true -->
                    <!-- 当前阶段 , curPhase ,typeName=text_input, isHideInSearch=true -->
                    <!-- 结束时间 , edate ,typeName=date_input, isHideInSearch=true -->
                    <!-- 附件 , fileId ,typeName=upload, isHideInSearch=true -->
                    <!-- 主键 , id ,typeName=text_input, isHideInSearch=true -->
                    <!-- 归属部门 , orgId ,typeName=button, isHideInSearch=true -->
                    <!-- 创建人员 , ownerId ,typeName=button, isHideInSearch=true -->
                    <!-- 项目介绍 , profile ,typeName=text_area, isHideInSearch=true -->
                    <!-- 项目状态 , projectStatus ,typeName=select_box, isHideInSearch=false -->
                    <div class="search-unit">
                        <div class="search-label-div" style="width:100px"><span th:text="${lang.translate('项目状态')}" class="search-label projectStatus-label">项目状态</span><span class="search-colon">:</span></div>
                        <div id="projectStatus" th:data="${enum.toArray('com.dt.platform.constants.enums.oa.ProjectStatusEnum')}" style="width:180px" extraParam="{}"></div>
                    </div>
                    <!-- 修改人ID , updateBy ,typeName=text_input, isHideInSearch=true -->
                    <!-- 计划工时 , planWorkTimeTotal ,typeName=text_input, isHideInSearch=true -->
                    <!-- 实际工时 , workTimeTotal ,typeName=text_input, isHideInSearch=true -->
                    <!-- 任务总数 , taskCount ,typeName=text_input, isHideInSearch=true -->
                    <!-- 进行中任务数 , taskActingCount ,typeName=text_input, isHideInSearch=true -->
                    <!-- 已完成任务数 , taskCompleteCount ,typeName=text_input, isHideInSearch=true -->
                    <!-- 任务完成率 , taskCompletePct ,typeName=text_input, isHideInSearch=true -->
                    <!-- 项目计划周期 , planTimeRange ,typeName=text_input, isHideInSearch=true -->
                    <!-- 进行中/已完成任务数 , taskStat ,typeName=text_input, isHideInSearch=true -->
                    <!-- taskRcdCount , taskRcdCount ,typeName=text_input, isHideInSearch=true -->
                    <!-- tabStatus , tabStatus ,typeName=text_input, isHideInSearch=true -->
                    <!-- 项目成员 , partUserStrList ,typeName=button, isHideInSearch=true -->
                    <!-- partUserList , partUserList ,typeName=text_input, isHideInSearch=true -->
                    <!-- 项目经理 , leaderId ,typeName=button, isHideInSearch=false -->
                    <div class="search-unit">
                        <div class="search-label-div" style="width:100px"><span th:text="${lang.translate('项目经理')}" class="search-label leaderId-label">项目经理</span><span class="search-colon">:</span></div>
                            <input lay-filter="leaderId" id="leaderId" name="leaderId"  type="hidden" class="layui-input"    lay-verify="|required"   />
                            <button id="leaderId-button" type="button" action-type="emp-dialog" class="layui-btn layui-btn-primary   " style="width: 180px"> <i class='layui-icon layui-icon-search'></i> <span th:text="${lang.translate('请选择人员')}" th:default-label="${lang.translate('请选择人员')}">按钮文本</span></button>
                    </div>
                    <!-- 项目类型 , type ,typeName=select_box, isHideInSearch=false -->
                    <div class="search-unit">
                        <div class="search-label-div" style="width:100px"><span th:text="${lang.translate('项目类型')}" class="search-label type-label">项目类型</span><span class="search-colon">:</span></div>
                        <div id="type" th:data="${'/service-system/sys-dict-item/query-paged-list?dictCode=oa_project_type'}" style="width:180px" extraParam="{}"></div>
                    </div>
                    <!-- 项目编号 , code ,typeName=text_input, isHideInSearch=false -->
                    <div class="search-unit">
                        <div class="search-label-div" style="width:100px"><span th:text="${lang.translate('项目编号')}" class="search-label code-label">项目编号</span><span class="search-colon">:</span></div>
                        <input id="code" class="layui-input search-input" style="width: 180px" type="text" />
                    </div>


                </div>
                <!-- 搜索输入区域 -->
                <div class="layui-form toolbar search-inputs">
                    <!-- 项目名称 , name ,typeName=text_input, isHideInSearch=false -->
                    <div class="search-unit">
                        <div class="search-label-div" style="width:100px"><span th:text="${lang.translate('项目名称')}" class="search-label name-label">项目名称</span><span class="search-colon">:</span></div>
                        <input id="name" class="layui-input search-input" style="width: 180px" type="text" />
                    </div>
                    <!-- 开始时间 , sdate ,typeName=date_input, isHideInSearch=false -->
                    <div class="search-unit">
                        <div class="search-label-div" style="width:100px"><span th:text="${lang.translate('开始时间')}" class="search-label sdate-label">开始时间</span><span class="search-colon">:</span></div>
                            <input type="text" id="sdate-begin" style="width: 180px" lay-verify="date" th:placeholder="${lang.translate('开始日期')}" autocomplete="off" class="layui-input search-input search-date-input"  readonly >
                            <span class="search-dash">-</span>
                            <input type="text" id="sdate-end"  style="width: 180px"  lay-verify="date" th:placeholder="${lang.translate('结束日期')}" autocomplete="off" class="layui-input search-input search-date-input" readonly>
                    </div>


                </div>
            </div>


            <!-- 按钮区域 -->
            <div id="search-area" class="layui-form toolbar search-buttons" style="opacity: 0">
                <button id="search-button" class="layui-btn icon-btn"><i class="layui-icon">&#xe615;</i>&nbsp;&nbsp;<span th:text="${lang.translate('搜索','','cmp:table.search')}">搜索</span></button>
            </div>
        </div>

        <div id="table-area" style="margin-top: 84px ">
            <table class="layui-table" id="data-table" lay-filter="data-table"></table>
        </div>

    </div>
</div>

<script type="text/javascript" src="/module/global.js" th:src="'/module/global.js?'+${cacheKey}"></script>
<script type="text/javascript" src="/assets/libs/jquery-3.2.1.min.js" th:src="'/assets/libs/jquery-3.2.1.min.js?'+${cacheKey}"></script>
<script type="text/javascript" src="/assets/libs/pandyle.min.js" th:src="'/assets/libs/pandyle.min.js?'+${cacheKey}"></script>
<script type="text/javascript" src="/assets/libs/layui/layui.js" th:src="'/assets/libs/layui/layui.js?'+${cacheKey}"></script>
<script type="text/javascript" src="/assets/libs/toast/js/toast.js" th:src="'/assets/libs/toast/js/toast.js?'+${cacheKey}"></script>
<!-- 表格工具栏 -->
<script type="text/html" id="toolbarTemplate">
    <div class="layui-btn-container">
        <button th:if="${perm.checkAuth('oa_project:create')}" id="add-button" class="layui-btn icon-btn layui-btn-sm create-new-button " lay-event="create"><i class="layui-icon">&#xe654;</i><span th:text="${lang.translate('新建','','cmp:table.button')}">新建</span></button>
    </div>
</script>

<!-- 表格操作列 -->
<script type="text/html" id="tableOperationTemplate">

    <button th:if="${perm.checkAuth('oa_project:view-form')}" class="layui-btn layui-btn-primary layui-btn-xs ops-view-button " lay-event="view"  data-id="{{d.id}}"> <span th:text="${lang.translate('查看','','cmp:table.ops')}">查看</span></button>
    <button th:if="${perm.checkAnyAuth('oa_project:update','oa_project:save')}" class="layui-btn layui-btn-primary layui-btn-xs ops-edit-button " lay-event="edit"data-id="{{d.id}}"><span th:text="${lang.translate('修改','','cmp:table.ops')}">修改</span></button>


    <button th:if="${perm.checkAuth('oa_project:delete')}" class="layui-btn layui-btn-xs layui-btn-danger ops-delete-button " lay-event="del" data-id="{{d.id}}"><span th:text="${lang.translate('删除','','cmp:table.ops')}">删除</span></button>

    <button class="layui-btn layui-btn-xs  action-close " lay-event="action-close" data-id="{{d.id}}"><span th:text="${lang.translate('关闭','','cmp:table.ops')}">关闭</span></button>
    <button class="layui-btn layui-btn-xs  action-open " lay-event="action-oepn" data-id="{{d.id}}"><span th:text="${lang.translate('开启','','cmp:table.ops')}">开启</span></button>

</script>


<script th:inline="javascript">
    var LAYUI_TABLE_WIDTH_CONFIG = [[${pageHelper.getTableColumnWidthConfig('data-table')}]];
    var SELECT_PROJECTSTATUS_DATA = [[${enum.toArray('com.dt.platform.constants.enums.oa.ProjectStatusEnum')}]];
    var AUTH_PREFIX="oa_project";

    // dataRange
    var DATA_RANGE = [[${dataRange}]] ;
    // pageType
    var PAGE_TYPE = [[${pageType}]] ;

</script>

<script th:src="'/business/oa/project/project_ext.js?'+${cacheKey}"></script>
<script th:src="'/business/oa/project/project_list.js?'+${cacheKey}"></script>

</body>
</html>